//魔改request类
/**
 * request 网络请求工具
 * 更详细的 api 文档: https://github.com/umijs/umi-request
 */
import {extend} from 'umi-request';
import {message} from 'antd';
import {stringify} from "querystring";
// import {history} from 'umi';
// import {getAccessToken, clearTokens} from './token'
// import stringUtil from '@/utils/stringUtil'


// const codeMessage = {
//   200: '服务器成功返回请求的数据。',
//   201: '新建或修改数据成功。',
//   202: '一个请求已经进入后台排队（异步任务）。',
//   204: '删除数据成功。',
//   400: '发出的请求有错误，服务器没有进行新建或修改数据的操作。',
//   401: '用户没有权限（令牌、用户名、密码错误）。',
//   403: '用户得到授权，但是访问是被禁止的。',
//   404: '发出的请求针对的是不存在的记录，服务器没有进行操作。',
//   406: '请求的格式不可得。',
//   410: '请求的资源被永久删除，且不会再得到的。',
//   422: '当创建一个对象时，发生一个验证错误。',
//   500: '服务器发生错误，请检查服务器。',
//   502: '网关错误。',
//   503: '服务不可用，服务器暂时过载或维护。',
//   504: '网关超时。',
// };

/**
 * 异常处理程序
 */
// const errorHandler = (error: { response: Response }): Response => {
//   const {response} = error;
//   if (response && response.status) {
//     const errorText = codeMessage[response.status] || response.statusText;
//     const {status, url} = response;
//     // console.log(status)
//     // 处理参数问题
//     let noParamUrl = url;
//     if (url.indexOf('?') !== -1) {
//       noParamUrl = url.substring(0, url.indexOf('?'));
//     }
//
//     if (url.indexOf('/system/oauth/token') !== -1) {
//       notification.error({
//         message: `请求错误 [20002]: ${noParamUrl}`,
//         description: '账号不存在或密码错误',
//       });
//       return response;
//     }
//     if (status === 401) {
//       notification.warn({
//         message: '请重新登陆!',
//       });
//       clearTokens();
//       history.push('/user/login');
//     } else {
//       notification.error({
//         message: `请求错误 [${status}]: ${noParamUrl}`,
//         description: errorText,
//       });
//     }
//   } else if (!response) {
//     notification.error({
//       description: '您的网络发生异常，无法连接服务器',
//       message: '网络异常',
//     });
//   }
//   return response;
// };

/**
 * 配置request请求时的默认参数
 */
const request = extend({
  // errorHandler, // 默认错误处理
  credentials: 'include', // 默认请求是否带上cookie
  prefix: process.env.NODE_ENV==='production'?'http://user-java.linhaijian.top':undefined   //根据运行环境添加访问地址的前缀
  // requestType: 'form',
});

/**
 * 所以请求拦截器
 */
request.interceptors.request.use((url, options): any => {
  return {
    url,
    options: {
      ...options,
      headers: {
        // Authorization: getAccessToken(),
      },
    },
  };
});

/**
 * 所有响应拦截器
 */
request.interceptors.response.use(async (response, options): Promise<any> => {
  // const {url, status} = response;
  // if (url.indexOf('/system/oauth/token') !== -1) {
  //   return response;
  // }
  // // 返回下载流的问题,可以在url添加标识
  // if (url.indexOf('/download/') !== -1) {
  //   if (status !== 200) {
  //     notification.error({
  //       message: `下载出错 : ${url}`,
  //     });
  //   } else {
  //     return await response.clone().blob();
  //   }
  //   return null;
  // }

  const res = await response.clone().json();
  if (res.code===0){
    return res.data
  }
  console.log(res)
  //无权限,则跳转
  if (res.code===40100){
    // message.error("请先登录");
    // @ts-ignore
    history.replace({
      pathname:'/user/login',
      search:stringify({
        redirect:location.pathname,
      })
    });
  }else{
    message.error(res.description)
  }
  return res.data;

  // console.log(data)
  // if ((status === 200 && data.code !== 1) || (status !== 200 && data.data !== undefined)) {
  //   // 处理参数问题
  //   let noParamUrl = url;
  //   if (url.indexOf('?') !== -1) {
  //     noParamUrl = url.substring(0, url.indexOf('?'));
  //   }
  //   const msg = (data.data === null || stringUtil.isEmpty(data?.data?.exceptionMsg)) ? data.msg : data.data.exceptionMsg;
  //   notification.error({
  //     message: `请求出错 [${data.code}]: ${noParamUrl}`,
  //     description: msg,
  //   });
  // }
  // return response;
});

export default request;
